package org.example.com.mapper;

import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.example.com.pojo.House;
import org.example.com.pojo.HouseTag;

import java.util.List;

@Mapper
public interface HouseMapper {

    /**
     * 获取推荐房源列表
     */
    List<House> findNearbyHouses();

    /**
     * 根据房源ID获取标签
     */
    List<HouseTag> findTagsByHouseId(Integer houseId);

    /**
     * 搜索房源列表（带分页）
     */
    List<House> searchHouses(@Param("keyword") String keyword,
                            @Param("provinceId") String provinceId,
                            @Param("cityId") String cityId,
                            @Param("districtId") String districtId,
                            @Param("minRent") String minRent,
                            @Param("maxRent") String maxRent,
                            @Param("paymentType") String paymentType,
                            @Param("orderBy") String orderBy,
                            @Param("orderType") String orderType,
                            @Param("offset") Integer offset,
                            @Param("limit") Integer limit);

    /**
     * 统计房源总数
     */
    Long countHouses(@Param("keyword") String keyword,
                    @Param("provinceId") String provinceId,
                    @Param("cityId") String cityId,
                    @Param("districtId") String districtId,
                    @Param("minRent") String minRent,
                    @Param("maxRent") String maxRent,
                    @Param("paymentType") String paymentType);

    /**
     * 根据ID获取房源详情
     */
    House findById(Integer id);

    /**
     * 添加房源
     * @param house
     */
    void add(House house);
}